Queue এবং Topic Management

Java Technologies - অ্যাপাচি অ্যাকটিভএমকিউ (Apache ActiveMQ) Apache ActiveMQ Web Console |
144
144

অ্যাপাচি অ্যাকটিভএমকিউ (Apache ActiveMQ) একটি মেসেজ ব্রোকার সিস্টেম যা বিভিন্ন ধরনের মেসেজ পাসিং প্যাটার্ন এবং যোগাযোগের পদ্ধতি সমর্থন করে। এর মধ্যে দুটি প্রধান যোগাযোগ পদ্ধতি হল Queue এবং TopicQueue এবং Topic ব্যবস্থাপনা অ্যাকটিভএমকিউ-তে মেসেজ রাউটিং এবং ভোক্তাদের মধ্যে যোগাযোগ পরিচালনা করার জন্য অত্যন্ত গুরুত্বপূর্ণ। এই দুটি মডেল মেসেজ পাসিং এবং প্রসেসিং এর জন্য আলাদা আলাদা পদ্ধতি প্রদান করে, এবং সিস্টেমের স্কেলেবিলিটি ও পারফরম্যান্স উন্নত করতে সাহায্য করে।

Queue Management

Queue হল পয়েন্ট-টু-পয়েন্ট (Point-to-Point) মেসেজ প্যাটার্নের জন্য ব্যবহৃত হয়। এটি এমন একটি কিউ যেখানে প্রোডিউসার একটি মেসেজ পাঠায় এবং কনজিউমার সেই মেসেজ গ্রহণ করে। কিউ ব্যবহারের মাধ্যমে মেসেজ FIFO (First In, First Out) পদ্ধতিতে সরবরাহ করা হয়, অর্থাৎ প্রথমে যে মেসেজ পাঠানো হবে, সেটি প্রথমে কনজিউমার দ্বারা গ্রহণ করা হবে।

Queue Management-এর বৈশিষ্ট্য

  1. One-to-One Communication: কিউ ব্যবহৃত হয় যখন একটি মেসেজ একটি নির্দিষ্ট কনজিউমারের কাছে পৌঁছানো প্রয়োজন।
  2. Load Balancing: যদি একাধিক কনজিউমার থাকে, তবে অ্যাকটিভএমকিউ মেসেজগুলো সবার মধ্যে সমানভাবে বিতরণ করবে, যাতে লোড ব্যালান্সিং নিশ্চিত হয়।
  3. Persistent Queue: কিউতে মেসেজ স্থায়ীভাবে (Persistent) সংরক্ষণ করা যায়, যাতে সিস্টেম রিস্টার্টের পরও মেসেজ হারানো না যায়।

Queue কনফিগারেশন উদাহরণ

<broker xmlns="http://activemq.apache.org/schema/core"
        brokerName="localhost"
        dataDirectory="${activemq.data}">
    
    <!-- Queue Configuration -->
    <destinationPolicy>
        <policyMap>
            <policyEntries>
                <policyEntry queue=">" memoryLimit="104857600" />
            </policyEntries>
        </policyMap>
    </destinationPolicy>

    <transportConnectors>
        <transportConnector uri="tcp://localhost:61616"/>
    </transportConnectors>
</broker>

এখানে:

  • queue=">" দ্বারা একটি সাধারণ কিউ কনফিগার করা হয়েছে যেখানে সমস্ত কিউয়ের জন্য এই পলিসি প্রযোজ্য হবে।
  • memoryLimit="104857600" দ্বারা কিউটির মেমরি সীমা নির্ধারণ করা হয়েছে, যাতে অতিরিক্ত লোড না হয়।

Topic Management

Topic হল পাবলিশ-সাবস্ক্রাইব (Publish-Subscribe) মেসেজ প্যাটার্নের জন্য ব্যবহৃত হয়। এটি একটি মেসেজ বিতরণ পদ্ধতি যেখানে প্রোডিউসার একটি মেসেজ পাঠায় এবং একাধিক কনজিউমার সেই মেসেজ গ্রহণ করতে পারে। Topic ব্যবহারের মাধ্যমে মেসেজ একাধিক সাবস্ক্রাইবারকে পাঠানো হয়, যেখানে একাধিক কনজিউমার একই মেসেজ গ্রহণ করে।

Topic Management-এর বৈশিষ্ট্য

  1. One-to-Many Communication: একটি প্রোডিউসার একটি টপিকে মেসেজ পাঠায় এবং একাধিক কনজিউমার সেই মেসেজ গ্রহণ করে।
  2. Broadcasting: এটি মেসেজ ব্রডকাস্টিংয়ের মতো কাজ করে, যেখানে একই মেসেজ একাধিক কনজিউমার বা সাবস্ক্রাইবারকে পাঠানো হয়।
  3. Message Delivery to Subscribers: মেসেজ শুধুমাত্র তাদের কাছে পৌঁছায় যারা নির্দিষ্ট টপিকে সাবস্ক্রাইব করেছে।

Topic কনফিগারেশন উদাহরণ

<broker xmlns="http://activemq.apache.org/schema/core"
        brokerName="localhost"
        dataDirectory="${activemq.data}">
    
    <!-- Topic Configuration -->
    <destinationPolicy>
        <policyMap>
            <policyEntries>
                <policyEntry topic=">" memoryLimit="104857600" />
            </policyEntries>
        </policyMap>
    </destinationPolicy>

    <transportConnectors>
        <transportConnector uri="tcp://localhost:61616"/>
    </transportConnectors>
</broker>

এখানে:

  • topic=">" দ্বারা সমস্ত টপিকের জন্য এই পলিসি প্রযোজ্য করা হয়েছে।
  • memoryLimit="104857600" দ্বারা টপিকের মেমরি সীমা নির্ধারণ করা হয়েছে।

Queue এবং Topic Management-এর মধ্যে পার্থক্য

বৈশিষ্ট্যQueueTopic
কমিউনিকেশন প্যাটার্নপয়েন্ট-টু-পয়েন্ট (Point-to-Point)পাবলিশ-সাবস্ক্রাইব (Publish-Subscribe)
ভোক্তা সংখ্যাএক বা একাধিক কনজিউমারএকাধিক কনজিউমার
মেসেজের ডেলিভারিএক কনজিউমারকে একটি মেসেজ পাঠানো হয়একাধিক কনজিউমারকে একই মেসেজ পাঠানো হয়
মেসেজ ফিল্টারিংFIFO (First In, First Out)সাবস্ক্রাইবারের সাবস্ক্রিপশন অনুযায়ী
লোড ব্যালান্সিংসমানভাবে মেসেজ বিতরণএকাধিক কনজিউমারদের মধ্যে মেসেজ ব্রডকাস্টিং
মেসেজ স্থায়িত্বস্থায়ী মেসেজ এবং ট্রানজ্যাকশনাল মেসেজব্রডকাস্ট মেসেজ, কিছু প্রোপার্টি ভিত্তিক

সারাংশ

  • Queue Management: এটি একাধিক কনজিউমারের মধ্যে মেসেজ ভাগ করার একটি পদ্ধতি যেখানে মেসেজ FIFO পদ্ধতিতে এক কনজিউমারকে পাঠানো হয়। এটি সাধারণত পয়েন্ট-টু-পয়েন্ট কমিউনিকেশনের জন্য ব্যবহৃত হয় এবং লোড ব্যালান্সিং নিশ্চিত করে।
  • Topic Management: এটি একাধিক কনজিউমারের মধ্যে মেসেজ ভাগ করার একটি পদ্ধতি যেখানে মেসেজ একাধিক সাবস্ক্রাইবারকে পাঠানো হয়। এটি পাবলিশ-সাবস্ক্রাইব মডেলে ব্যবহৃত হয় এবং মেসেজ ব্রডকাস্টিং নিশ্চিত করে।
  • অ্যাকটিভএমকিউ-তে কিউ এবং টপিক কনফিগারেশনের মাধ্যমে আপনি মেসেজ পাসিং এবং রাউটিং ম্যানেজ করতে পারেন, যা সিস্টেমের স্কেলেবিলিটি এবং পারফরম্যান্স নিশ্চিত করে।

এগুলি অ্যাপাচি অ্যাকটিভএমকিউ-তে মেসেজ ট্রান্সপোর্ট এবং যোগাযোগ ব্যবস্থাকে আরও কার্যকরী এবং স্কেলযোগ্য করে তোলে।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion